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(54) Converting numbers between measurement systems based upon semanticaily labeled 
strings 



(57) A method, system, and apparatus are provided 
for converting numbers between different units of meas- 
urement. When a string of text is entered Into an appli- 
ca^on program, the string Is analyzed to determine 
whether the string of text includes a number having an 
associated unit name. If the string of text includes a 
number having an associated unit name, the number is 
semanticaily labeled with schema infomriation that iden- 
tifies the unit name as a source unit of measurement. 



When a selection is received of the number or an indi- 
cation that the numl>er Is labeled with schema informa- 
tion, a list of actions may be provided identifying con- 
version options available iforthe number. One of the con- 
version options may then be selected resulting In the 
conversion of the selected number to the destination 
unit of measure identified by the selected action. The 
converted number may then be inserted Into the string 
of text to replace the selected number along with a unit 
name conresponding to the destination unit of measure. 
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Description 
Technical Field 

[0001] Embodiments of the present Invention relate to & 
the field of unit measurement conversion. More partic- 
ularty, embodiments of the Invention relate to the field 
of converting numbers between measurement systems 
based upon semanticaify labeled strings. 

10 

Backflround of the Invention 



[0005] Therefore, in light of the above, there Is a need 
for a method, system, and apparatus for easily convert* 
Ing numbers between measurement systems that do not 
require a user to utilize an external application or Web 
site to convert numbers between measurement sys- 
tems. Moreover, there is a need for a method, system, 
and apparatus for converting numbers between sys- 
tems of measure that can present conversion options to 
the user in a user-selected user Interface language. 

Sumntary of ttte Invention 



[0002] As a result of the advent and explosion of the 
internet and the World Wide Web ("Web"), computer us- 
ers today frequently receive electronic docunoents from 
other users located in countries throughout the world. 
Electronic documents such as these often Include num- 
bers expressed in a unit of measurement utilized in the 
sender's particular country. For instance, users located 
in the United States are likely to express numbers in the 
Imperial system of measurement (e.g. Inches, feet, 
etc.), while European users are likely to express num- 
bers in the Metrto system of measurement (e.g. centim- 
eters, kilometers, etc). 

[0003] When users receive electronic documents 
having numbers expressed In measurement systems 
other than the system used \n their native country, users 
may need to convert the numt>ers to their local meas- 
urement system to understand the meaning of the 
numt>er. For instance, a user may want to convert a 
numt>er expressed in degrees Fahrenheit, which Is a 
unit of measure for temperatures commonly used in the 
United States, to degrees Celsius, which is a unit of 
measure for temperatures commonly used in Europe. 
However, converting numbers between measurement 
systems in this manner has heretofore been difficult for 
a user to accomplish easily. 

[0004] Prevtously, if a user wanted to convert a 
number contained in an electronic document, such as a 
word processing document, between measurement 
systems, the user would first have to copy the number 
to be converted to a clipboard. The user would then 
paste the number Into an external program or Web site 
capable of converting the number to the desired desti- 
nation unit of measure. Once the external program or 
Web site had completed the conversion, the user may 
copy the converted number to the clipboard and then 
paste the converted number back into the electronic 
document. Although systems such as these do allow a 
user to convert a number between measurement sys- 
tems, these systems can be difficult for to use because 
of the large number of steps required to complete the 
conversion. Moreover, these previous solutions require 
the user to perform the conversion using the user inter- 
face language of the conversion program or Web site. 
This can be extremely frustrating for a user that does 
not understand the language of the conversion program 
or Web site. 



[0006] Embodiments of the present inventk>n solve 
the above-described problems by providing a method, 

IS system, and apparatus for easily converting numbers 
between measurement systems and units that do not 
require the use of an external application or Web site to 
convert the numbers. Moreover, embodiments of the 
present Invention provide a method, system, and appa- 

20 mtus for converting numbers between units that can 
present conversion options to the user in a user-select- 
ed Interface language. Moreover, embodiments of the 
invention provide an extensible architecture through 
which a user may add conversion mies that enable con- 

2$ version of numbers between measurement systems not 
initially supported. 

[0007] According to one actual embodiment of the 
present invention, a method is provided for converting 
a number between measurement systems in a system 

30 for creating and editing an electron^ document. Accord- 
ing to this embodiment of the invention, software mod- 
ules are executed in conjunction with a software appli- 
cation for creating and editing an electronic document 
that allow the convenient conversion of numbers be- 

35 tween measurement units. When a user types a string 
of text, such as a paragraph into the software applica- 
tion, the string is analyzed to detemnine whether the 
string of text includes a number having an associated 
unit name. For Instance, a user may type the number 

40 MO' and the associated unit name 'km', for kifometers. 
if the string of text includes a number having an associ- 
ated unit name, the number is semantkrally labeled with 
schema information that Identifies the unit name as a 
source unit of measure. For instance, if a string of text 

"ts Includes the number "10' followed by the unit of meas- 
ure 'l^m*, schema information will be associated with the 
number Indicating that the number Is expressed with a 
source unit of measure. 

[0008] Once a number having an associated unit 
so name has been identified within a string of text, such as 
a paragraph, the application may display an indication 
to the user that the number has been semanticaliy la- 
beled. This indication also identifies to the user that ac- 
tions may be performed on the number. When a selec- 
ts tion is received of the number or the indication, a list of 
actions may be provided to the user identifying conver- 
sion options available for the number. For instance, if 
the identified number includes an associated unit name 
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•m", for motefB, an action menu Hem may be displayed 
to the user for converting the number to feet or yards. 
Other types of conversion options may also be present- 
ed to the user for converting the number. 
[0009] According to one embodiment of the Invention, 
a cun'ent user interface language setting for the appli- 
cation program is detennlned prk>r to providing the list 
of actions to the user. When the user selects the list of 
actions, the available actions are displayed to the user 
in a language specified by the current user interface lan- 
guage setting. In this manner, the user is always pre- 
sented the conversion options In the current user Inter- 
face language. Actions may also be included in the list 
of actions only for conversions supported for the current 
user interface language setting and may also be speci- 
fied as being enabled for use with all user Interface lan- 
guages. 

[0010] After the list of actions has been displayed to 
the user, a selection of one of the actions may be re- 
ceived. In response to receMng the selection of a con- 
version action, a converted number may be generated 
by converting ttie selected number to the destination 
unit of measure Identified by the selected action. Once 
the conversion is completed, the converted number and 
its associated unit name may be inserted Into the string 
of text to replace the selected number and Its associated 
unit name. According to various embodiments of the 
present invention, a document object model supported 
by the applicatton program may be utilized to insert the 
converted number Into the string of text. Altematively. 
the converted number may be displayed to the user. 
[0011] According to another embodiment of the 
present invention, a system Is provided for converting a 
number between measurement systems. According to 
this embodiment of the invention, the system includes 
a recognizer plug-In capable of receiving a portion of an 
electronic document as a string of text from an applica- 
tion program. For Instance, the recognizer plug-In may 
receive a paragraph of text from an application program 
as it is typed by the user. Once the recognizer plug-In 
has receded the string of text, the recognizer plug-In 
analyzes the string of text to detemnlne whether the 
string of text includes a number having an associated 
unit name. If the string of text includes a number having 
an associated unit name, the recognizer plug-in seman- 
tically labels the number with schema Infomnation iden- 
tifying the unit name as a source unit of measure and 
identifying the language used to express the string of 
text. This information is then passed by the recognizer 
plug-In back to the application program. 
(001 2] According to one embodiment of the Invention, 
the system also includes an application program for cre- 
ating and editing an electronic document. For Instance, 
the application program may comprise a word proces- 
sor, a spreadsheet application program, an e-mail ap- 
plication which Includes editing functions, or other types 
of application programs for creating and editing elec- 
tronic documents. According to this embodiment of the 



Invention, the application program Is capable of display- 
ing the string of text along with an Indication that the 
number has been semantically labeled by the recogniz- 
er plug-In. This Indication may comprise a user Interface 

5 object for indicating to a user that the number has been 
semantically labeled and that conversion actions may 
be performed on the number. 
[0013] The application program may also be opera- 
tive to receive a selection of the number or the indication 

10 and to provide a list of actions that may be perfonned 
on the number to convert the number to another meas- 
urement unit. The application may then receh^e the se- 
lection of one of the list of actions and provide the se- 
lection and the number to an action plug-in. 

75 [001 4] The system also includes an action plug-In that 
Is capable of generating a converted number by con- 
verting the selected number to the destination unit of 
measurement identified by action selected from the list 
of actions. The action plug-In is also operative to replace 

20 the selected number and Its associated unit name with 
the converted nurifiber and Its associated unit name in 
the string of text. According to one actual embodiment 
of the Invention, the action plug-in may replace the 
number with the converted number In the string of text 

2$ by accessing a document object model provided by the 
application program. Altematively, the converted 
number and its associated unit name may be displayed. 
[0015] According to various embodiments of the 
present Invention, the system provided herein may also 

30 include an action plug-in that Is operative to register with 
the application program prior to perfonming any conver- 
sion functions. As a part of the registration procedure, 
the action plug-in may provide the list of actions that may 
be perfomied on the number to convert the number to 

35 another measurement system to the application pro- 
gram. Moreover, when creating the list of actions, the 
action plug-In may determine a cun^nt user Interface 
language setting for the application program and gen- 
erate the action menu items in a language specified by 

40 the cu n-ent user Interface language setting. Additionally, 
the action plug-in may also consult a conversion settings 
file to generate action menu Items for each source unit 
name enabled for use with ail enabled languages and 
for each source unit name enabled for use with the cur- 

45 rent user Interface language. The contents of the con- 
version settings file may be modified by a user to enable 
conversion between measurement systems other than 
those Initially defined in the conversion settings file. 
[0016] Other embodiments of the present invention 

so provide a computer-controlled apparatus and a compu- 
ter-readable medium for converting numbers between 
measurement systems based on semantically labeled 
strings. These and other details regarding the various 
embodiments of the Invention will become more appar- 

55 ent from the detailed description that follows. 
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Brief Description of the Drawings 
[0017] 

FIGURE 1 A Is a block diagram showing the archi- 
tecture of a personal computer that provides an il- 
lustrative operating environment for emt)odiments 
of the present invention; 

FIGURE 1B Is a block diagram showing the fonnat 
and contents of a conversion settings file utilized In 
various embodi ments of the present invention to de- 
fine available conversions; 
FIGURE 2 Is a block diagram that shows a software 
architecture for recognizing, labeling, and perform- 
ing actions on recognized strings of text according 
to various embodiments of the present Invention; 
FIGURES 3A-3D are screen diagrams showing 
screen displays including an action menu for con- 
verting numbers between measurement systems 
provided by various embodiments of the present in- 
vention; 

FIGURE 4 Is a flow diagram showing an Illustrative 
routine for registering an action plug-in with an ap- 
plkjation program according to one actual embodi- 
ment of tiie present invention; 
FIGURE 5 is a flow diagram showing an illustrative 
routine for processing a string input provided at an 
applteation program according to one actual em- 
bodiment of the present Invention; 
FIGURE 6 is a flow diagram illustrating the opera- 
tion of a recognizer plug-In sofhvare module provid- 
ed according to one actual embodiment of the 
present invention; 

FIGURE 7 is a flow diagram illustrating a routine for 
processing the selection of a semantteally catego- 
rized numtjer according to one actual embodiment 
of the present invention; and 
FIGURE 8 is a flow diagram showing a routine for 
executing an action plug-In for converting numbers 
between measurement units according to one ac- 
tual embodiment of the present Invention. 

Detailed Description of an Illustrative Emt>odIment 

[0018] As described briefly above, embodiments of 
the present Invention provide a method, system, appa- 
ratus, and computer-readable nrwdium for converting 
numbers between units of measure. In the following de- 
tailed description, references are made to the accom- 
panying drawings that fonn a part hereof, and In which 
are shown by way of illustration specific embodiments 
or examples. These embodiments may be combined, 
other embodiments may be utilized, and stmctural 
changes may be made without departing from the spirit 
and scope of the present Invention. The following de- 
tailed description is, therefore, not be taken in a limiting 
sense, and the scope of the present invention is defined 
by the appended claims and their equivalents. 



[001 9] Referring now to the drawings, In which like nu- 
merals represent like elements through the several fig- 
ures, aspects of the present Invention and the Illustrative 
operating environment will be descnl>ed. FIGURE 1A 

5 and the following discussion are Intended to provkle a 
brief, general description of a suitable computing envi- 
ronment In whic^ the Invention may be implemented. 
While the invention wilt be described In the general con- 
text of program modules that execute In conjunction with 

10 an application program that mns on an operating system 
on a personal computer, those skilled in the art will rec- 
ognize that the Invention may also be Implemented in 
combination with other program modules. Additional as- 
pects of an illustrative operating environment and soft- 

15 ware architecture for implementing the various embod- 
iments of the present Invention are described In U.S. 
Patent Application No. 09/588,411 , entitled 'Method and 
System for Semantk^ally Labeling Strings and Providing 
Actions Based on Semantically Labeled Strings", which 

20 is expressly inoorporated herein by reference. 

[0020] Generally, program modules Include routines, 
programs, components, data structures, and other 
types of stnictures that perfomi particular tasks or im- 
plement partfcular abstract data types. Moreover, those 

25 skilled in the art will appreciate that the invention may 
be practiced with other computer system configurations, 
including hand-held devtees, multiprocessor systems, 
microprocessor-based or programmable consumer 
electronics, minicomputers, mainframe computers, and 

30 the like. The Invention may also be practiced In distrib- 
uted computing environments where tasks are per- 
formed by remote processing devices that are linked 
through a communications network. In a distributed 
computing environment, program modules may be ky 

35 cated In both local and remote memory storage devices. 
[0021] Tuming now to FIGURE 1A, an illustrative 
computer architecture for a personal computer 2 for 
practicing the various embodiments of the invention will 
be described. The computer architecture shown In FIG- 

40 URE 1A illustrates a conventional personal computer, 
Including a central processing unit 4 CCPU*), a system 
memory 6, including a random access memory 8 
("RAM") and a read-only memory ("ROM") 10, and a 
system bus 12 that couples the memory to the CPU 4. 

45 A basic input/output system containing the basic rou- 
tines that help to transfer Information between elements 
within the computer, such as during startup, Is stored in 
the ROM 10. The personal computer 2 further includes 
a mass storage device 14 for storing an operating sys- 

50 tem 16, application programs, such as the application 
program 205. and data. 

[0022] The mass storage device 14 is connected to 
the CPU 4 through a mass storage controller (not 
shown) connected to the bus 12. The mass storage de- 
55 vtoe 14 and Its associated computer-readable media 
provide non-volatile storage for the personal computer 
2. Although the description of computer-readable media 
contained herein refers to a mass storage device, such 



7 



EP1361 523 A2 



8 



as a hard disk or CD-ROM drivd, tt should be appreci- 
ated by those skilled In the art that computer-readable 
media can be any avaftabte media that can be accessed 
by the personal computer 2. 
[0023] By way of example, and not limitation, compu- 
ternreadable media may comprise computer storage 
media and communlcatk>n media. Computer storage 
media includes volatile and non-volatile, removable and 
non-removable media implemented in any method or 
technology for storage of information such as computer- 
readable Instructions, data structures, program mod- 
ules or other data. Computer storage media Indudes. 
but Is not Umited to, I=IAM, ROM, EPROM, EEPROM, 
flash memory or other solid state memory technology, 
CD-ROM, DVD, or other optical storage, magnetic cas- 
settes, magnetto tape, magnetic disk storage or other 
magnetic storage devices, or any other medium whtoh 
can be used to store the desired infomiatlon and which 
can be accessed by the computer. 
[0024] According to various embodiments of the in- 
vention, the personal computer 2 may operate in a net- 
worked environment using logical connections to re- 
mote computers through a TCP/IP network 18, such as 
the internet. The personal computer 2 may connect to 
the TCP/IP network 18 through a network Interface unit 
20 connected to the bus 12. It should be appreciated 
that the network interface unit 20 may also be utilized to 
connect to other t^3es of nehvorks and remote computer 
systems. The personal computer 2 may also include an 
Input^output controller 22 for receiving and processing 
input from a number of devices, including a keyboard or 
mouse (not shown). Similarly, an Input/output controller 
22 may provide output to a display screen, a printer, or 
other type of output device. 

[0025] mentioned briefly above, a number of pro- 
gram modules and data files may be stored in the mass 
storage device 14 and RAM 8 of the pereonal computer 
2, including an operating system 16 suitable for control- 
ling the operation of a networked personal computer, 
such as the WINDOWS XP operating system from MI- 
CROSOFT CORPORATION of Redmond. Washington. 
The mass storage device 14 and RAM 8 may also store 
one or more appltoation programs. In particular, the 
mass storage device 14 and RAM 8 may store an appli- 
cation program 205 for creating and editing an eiectronk; 
document 24. For instance, the application program 205 
may comprise a word processing application program 
and the electronic document 24 may comprise a word 
processing document The application program 205 
may also comprise a spreadsheet application program 
and the eteotronic document 24 comprise a spread- 
sheet. Similarly, the application program 205 may com- 
prise an electronic mail application program and the 
electronic document 24 may comprise an electronic mall 
message. /Application programs for creating and editing 
other types of electronic documents may also be used 
with the various embodiments of the present invention. 
[00261 Embodiments of the present Invention provide 



prograrri modules for use In conjunction with the appli- 
cation program 205 that convert numbers contained 
within the electronic document 24 between units of 
measure, also refered to herein as measurement units 
6 or measurement systems. In particular, embodiments of 
the Invention provide a r^ognizer plug-In 220 and an 
ac^n plug-in 225. As wlO be described In greater detail 
below, the recognizer plug-in 220 recognizes numbers 
having an associated unit name contained within an 
w electronic document 24 and labels the numbers with se- 
mantic Information klentlfylng the unit name as a source 
unit of measure. The recognizer plug-in 220 then passes 
this information to the appltoation program 205 for use 
by the action plug-in 225. The action plug-in 225 par- 
ts forms actions on the recognized numbere for converting 
between units of measure. The available conversions 
are defined In the conversion settings file 28. Additional 
details regarding the convereion settings file 28 are de- 
scribed below with reference to FIGURE IB. 
[0027] According to various embodiments of the 
present invention, the action plug-in 225 may also gen- 
erate a list of actions that may be performed on a given 
number. As a part of this process, the action piug-in 225 
may query language settings 26 of the applk^atlon pro- 
gram 205 or operating system 16. The language set- 
tings 26 specify the current user interface language. The 
list of actions may then be created in the current user 
interface language. Moreover, the action plug-tn 225 
may also consult the conversion settings file 28 to gen- 
erate action menu Items for each source unit name en- 
abled for use with all envied languages and for each 
source unit name enabled for use with the cunent user 
Interface language. Additional details regarding the op- 
eratton of the recognizer plug-in 220 and the action piug- 
in 225, including the use of the conversion settings file 
28 and the language settings 26, will be described in 
greater detail below. 

[0026] Referring now to FIQURE 1 B, various aspects 
of the conversion settings file 28 will be described. As 
discussed briefly above, the conversion settings file 28 
is utilized by both the recognizer plug-In 220 and the 
action plug-in 225. In particular, the recognizer plug-in 
220 utilizes portions of the conversion settings file 28 to 
detenDine the source unit names that shoukJ be recog- 
nized within a string of text, and the action plug-In 225 
utilizes the conversion settings file 28 to create the ac- 
tion menus that should be presented to the user and to 
actually perform conversions. Additional details regard- 
ing the use of the conversion settings file 28 by the rec- 
ognizer plug-in 220 and the action piug-in 225 will be 
described In greater detail below. 
[0029] As shown in FIGURE IB, the conversion set- 
tings file 28 comprises a data file having fields 50A-50J. 
The field 50A contains a locale identification CLCIO") 
number for which a particular conversion should be en- 
abled. As known to those skilled in the art, when used 
in conjunction with the WINDOWS XP operating system 
from MICROSOFT CORPORATION of Redmond. 
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Washington, the LCID Is an identification number used 
to identify locales and languages. The LCID Is used 
herein to ensure that conversion options will be present* 
ed to the user only for conversions that are enat>led for 
use with the currently enabled language. Altemativelyt 
the field 60A may include the phrase "ALL*, thereby en- 
abling the conversion for use with all enabled languag- 
es. Additional details regarding the use of the field 50A 
will be described below. 

[0030] The conversion settings file 28 also includes a 
field SOB representing the source unit name. The source 
unit name is the name of the source unit of measure that 
is associated with a recognized number. The recognizer 
plug-in 220 uses the field 508 to identify those source 
unit names that it should recognize. The conversion set- 
tings file 28 also includes a field 50C that Includes a 
source description corresponding to the source unit 
name identified In the field SOB. The contents of the field 
50C may be localized for a particular locale. The con- 
version settings file 28 also includes a field SOD that In- 
dicates whether a space Is located between the source 
unit name and number. Some regional formats utilize a 
space between a number and a unit name while others 
do not. The field SOD Is therefore utilized by the recog- 
nizer plug-In 220 to recognize numbers expressed using 
either fonriat. The conversion settings file 28 also In- 
dudes a field SOE that defines whether the case of the 
source unit name should be considered by the recog- 
nizer plug-in 220. 

[0031] The conversion settings file 28 also includes 
the field 50F which contains data identifying the desti- 
nation unit name and a field 50Q which contains data 
Identifying the destination description. As with the field 
50C, the field 50G may be localized for a particular lo- 
cale. A field 50H is also included that Indicates whether 
a space should be placed between the destination 
number and its associated unit name in the conversion 
result. The field SOH is utilized by the action plug-in 225 
when fomnatting conversion results. 
[0032] The conversion settings file 28 also Includes a 
field 501 Indicating the number of decimal places that 
should be utilized when rounding the converted result. 
The field 501 may be changed for each conversion. Typ- 
ically, the rounding precision value contained in field 501 
is adjusted for conversions where the destination value 
is much larger or much smaller than the source number. 
[0033] The conversion settings file 28 also includes a 
field 50J which defines the conversion ratio or formula 
reference that should be utilized for a particular conver- 
sion. Where a conversion is pert onmed by multiplying by 
a coefficient, the field 50J contains the coefficient. 
Where a conversion is performed utilizing a more com- 
plex equation, the field 50J may include a formula ref- 
erence to the appropriate formula. For Instance, the field 
50J may include a reference to a fomnula for converting 
Celsius values to Fahrenheit values, such as 'CTOFV 
Other types of fonnula references may also be provided 
for performing more complex conversions. 



[0034] The conversion settings file 28 shown in FIG- 
URE IB Includes several illustrative conversion entitas 
52A-52E. The entry 52A conresponds to a conversion 
from kilometers to miles and Is enabled for all languag- 

5 es. The entry S2B corresponds to a conversion from de- 
grees Celsius to degrees Fahrenheit and Is also enabled 
for all languages. The entries S2C-52D convert between 
Swedish 'long' miles and kilometers and are only ena- 
bled when the active user interface language conne- 

10 spends to the LCID •1054." The entry 52E corresponds 
to a conversion from kilometers to yards and is also en- 
abled for all languages. 

[0035] It should be appreciated by the reader that the 
entries 52A-52E are merely illustrative examples of the 

15 types of conversions that may be defined in the conver- 
sion settings file 28 and that other types of conversions 
may be stmitarty defined. In particular, converstons may 
be defined between miles and kilometers, Inches and 
centimeters, millimeters and Inches, feet and centime- 

20 ters. meters and feet, yards and meters, acres and hec- 
tare, U.K. pints and liters, U.S. pints and liters, liters and 
gallons, ounces and deciliters, quarts and liters, pounds 
and kibgrams, mites per hour and kilometers per hour, 
and other measurement units. Moreover, It should be 

25 appreciated that addttional conversions may be defined 
by adding an appropriate entry to the conversion set- 
tings file 28 defining the new conversion. 
[0036] Referring now to FIGURE 2, an illustrative soft- 
ware architecture for use In conjunction with the various 

30 embodiments of the present invention will be described. 
The architecture shown In FIGURE 2 includes an appli- 
cation program 205, such as a word processor applica- 
tion program, a spreadsheet application program, or 
other type of application program for creating and edit- 

35 ing electronic documents. The applteallon program 205 
may also comprise a Web browser. 
[0037] The application program 205 is able to com- 
municate with a recognizer dynamteally linked library 
("DLL") 210 and an action DLL 21 5. As will be described 

40 in greater detail below, the recognizer DLL 21 0 controls 
one or more recognizer plug-ins 220A-220N and the ac- 
tion DLL21 6 controls one or more action plug-ins 225A- 
225N. 

[0038] According to one embodiment of the Invention, 
45 the recognizer plug-Ins 220A-220N and the action plug- 
ins 225A-225N are automation servers. Automation 
servers are well-known software components that are 
assembled Into programs or add functionality to existing 
programs running on the WINDOWS XP operating sys- 
50 tern from MICROSOFT CORPORATION of Redmond. 
Washington. Automation servers may be written in a va- 
riety of computing languages and can be plugged and 
unplugged from a program at runtime without having to 
recompile the program. 
55 [0039] The recognizer DLL 210 handles the distribu- 
tion of text strings from an electronic document being 
edited by the applrcation program 205 to the individual 
recognizer plug-Ins 220A-220N. The recognizer plug- 
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Ins 220A-220N recognize particular strings In an elec- 
tronic document, such as a word processing document 
or a spreadsheet document The recognizer plug-Ins 
220A*220N may be packaged with the application pro- 
gram module 206 or they may be written by third parties s 
to recognize partlcutar strings of Interest. Typically, the 
recognizer DLL 210 passes strings to the recognizer 
plug-Ins 220A-220N in single paragraphs or ceil value 
increments. However, strings may be passed to the rec- 
ognizer plug-ins 220A-220N in other sizes and fonmats. 
[0040] As part of recognizing certain strings as includ- 
ing semantic Infonmatlon, the recognizer plug-ins 220A- 
220N detemilne which strings are to be labeled and how 
they are to be labeled. After receiving these results f mm 
the various recognizer plug-ins 220, the recognizer DLL 
210 sends semantic categories to the application pro- 
gram module 205. According to one a^ual embodiment 
of the invention, a recognizer plug-in 220 is provided for 
recognizing strings as containing numbers havir>g an 
assodated unit nanie. According to this embodiment of ^ 
the Invention, the semantic category comprises schema 
information that IdenWIes the unit name as a source unit 
of measure. The schema Information may also include 
informaton identifying the language in which the string 
of text is expressed. This information is returned to the 2S 
recognizer DLL 21 0 by the recognizer plug-in 220 along 
with other information that may be utilized by a corre- 
sponding action ptug-in 225. such as a copy of the 
number, the source unit name, and the language that 
the string of text is expressed in. Additionally, the rec- so 
ognlzer plug-in 220 may return Infomiation identifying 
the location of the number within the text string, includ- 
ing the length of the text string and the character number 
of the first letter of the number. 

[0041] It should be appreciated that each of the rec- S5 
ognlzer plug-Ins 220A-220N are executed separately. 
The recognizer Dl_L 210 is responsible for handling the 
asynchroniclty that results from different recognizer 
plug-ins 220A-220N returning results at different times. 
In this manner, various types of data may be recognized 
within a text string and different actions provided for 
each semantically labeled string. Additional details re- 
garding the operation of the recognizer plug-in 220 for 
recognizing numbers wili be described below with refer- 
ence to FIGURES 3-8. 

[0042] After a string is labeled by a recognizer plug- 
in 220A-220N, schema Information is sent to the appfi- 
catlon program module 205. A user of the application 
program module 205 may then execute actions that are 
associated with the schema infomnation on the recog- so 
nized string. The action DLL 215 manages the action 
plug-ins 225A-225N that are executed in order to per- 
form the actions. As with the recognizer plug-Ins 220A- 
22N, the action plug-Ins 225A-225N may be paclcaged 
with the application program module 205 or written by ss 
third parties to perfomn particular actions that are of in- 
terest The action plug-ins 225A-225N provide possible 
actions to be presented to the user based upon the 
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schenm Information, or type label, associated with the 
string. As will be described in greater detail below, the 
list of actions provided to the user is dynamically gener- 
ated for each schema type. This information Is then pro- 
vided to the application program 205 which displays the 
list of actions to the user when the string Is selected. 
[0043] After an action has been chosen from the list 
of actions, the action DLL 215 manages the appropriate 
action plug-in 225A-225N and passes the necessary in- 
formation between the action plug-In and the application 
program module 205 so that the action plug-In may ex- 
ecute the desired action. Typically, the application pro- 
gram module 205 sends the action DLL 21 5 an automa- 
tion request to invoke the action the user has selected. 
As will be described in greater detail below, according 
to one embodiment of the invention, an action ptug-in 
225 is provided that converts recognized numl^ers to 
other units of measure. Addition details regarding the 
operation of the action plug-In 225 and the schema in- 
fomiation utilized to Identify different source unit names 
will be described in greater detail below with reference 
to FIGURES 3-8. 

[0044] Referring now to FiQURES 3A-3D, an Illustra- 
tive user interface provided by the various embodiments 
of the present invention will be descrit>ed. As shown In 
FIGURE 3A, a number 32 including an associated unit 
name may be typed by a user into an appilcatlon pro- 
gram 205, such as a word processor, as a part of a string 
of text. Once the user has provided the string of text, the 
string of text is provided to a recognizer plug-in 220 that 
recognizes numbere contained within the string of text, 
such as the number 32. The number 32 having an as- 
sociated unit name Identified by the recognizer plug-in 
220 is identified to the application program module as a 
type of semantic infonnation upon which actions may 
be perfomned. Therefore, the application program mod- 
ule 205 provides an indication to the user that actions 
may be performed on the numt>er 32. This indication 
may be provided to the user by highlighting the number 
32 or providing a user interface indication 34 in proximity 
to the numtwr 32. 

[0045] When the number 32 or the indication 34 is se- 
lected by a user, a list of actions is displayed that may 
be performed on the number to convert the number to 
another unit of measure. This list of actions may com- 
prise a dropdown menu 36 having one or more menu 
items corresponding to the list of actions that may be 
performed on the number 32. According to one embod- 
iment of the InvenUon, the contents of the dropdown 
menu 36 may be displayed in one of many different lan- 
guages. The language in which the dropdown menu 36 
is displayed is based on a current interface user lan- 
guage for the application program module 205 or the 
operating system 16. In this manner, international users 
throughout the world will be displayed a dropdown menu 
36 in their currently installed and active user interface 
language. 

[0046] As shown In FIGURE 3A, the dropdown menu 
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36 indudos another Indication of the numt>6r 32 to be 
converted. The dropdown menu 36 also includes a list 
of actions 38 that may t>e performed to convert the 
number 32 to other measurement systems. According 
to one embodiment of the Invention, the list of actions 
38 displayed In the dropdown menu 36 is limited to con- 
version options specified for use with the cunentty ena* 
bled user Interface language on the personal computer 
2. In this manner, actions for converting numbers not 
relevant to the currently enabled language of the per- 
sonal computer 2 will not be shown in the dropdown 
menu 36. 

[0047] As shown in FIGURE 3A, the application pro- 
gram nruxiule 205 also adds menu Items 44A and 44B 
to (he dropdown menu 36. The selection of item 44A 
removes the semantic labeling from the selected text. 
Other recognized text in the same (or other) documents 
will remain labeled, and newly typed text will still be sub- 
ject to continued recognition and labeling. The selection 
of Item 446 provides a list of user selectable preferences 
defining the operation and behavior of the recognizer 
and action plug-Ins. 

[0048] As described briefly above, when a number 32 
having an associated unit name Is recognized by the 
recognizer plug-in 220, the numl>er 32 is labeled with 
schema Infonnatlon Identifying the associated unit 
name as a source unit of measure. Additionally, the lan- 
guage of the string of text may also be identified in the 
schema Infomnatlon. This schema infomnation is (hen re- 
turned to the application program 205 and is utilized by 
the action plug-in 225 to determine the appropriate list 
of actions 38 that should be included In the dropdown 
menu 36, In this manner, only conversion operations 
consistent witli the source unit of measure and the lan- 
guage used to express the string of text are provided to 
the user via the dropdown menu 36. 
[0049] The number 32 shown in FIGURE 3A is ex- 
pressed in )<i1ograms. Therefore, the dropdown menu 36 
includes actions in the list of actions 38 for converting 
the numt>er 32 to pounds, and to stones and pounds. 
Simiiarty, the number 32 shown in FIGURE 3B is ex- 
pressed In meters. Therefore, the dropdown menu 36 
includes actions In the list of actions 38 for converting 
the number 32 to feet and to yards. Likewise, the 
number 32 shown In FIGURE 3D is shown degrees Cel- 
sius. Therefore, the dropdown menu 36 includes only 
an action for converting the number 32 from degrees 
Celsius to degrees Fahrenheit. Also, the list of actions 
38 shown in FIGURES 3A, 3B, and 3D is displayed Eng- 
lish. It should be appreciated, however, that the drop- 
down menu 36 would appear in another language If a 
language other than English was selected as the current 
user Interface language on the personal computer 2. 
[0050] As shown in FIGURE 3C, once the user has 
selected an action from the list of actions 38, the con- 
version of the number 32 is performed according to the 
selected action. The converted number may then be dis- 
played to the user in a dialog box 37 as shown in FIG- 
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URE 3C. Altemath^ly, the number 32 may be replaced 
In the string of text with the converted number and the 
unit name associated with the destination unit of meas- 
urement. The number 32 may be replaced In the string 

6 of text using a document object model provided by the 
application program 205. This process is described in 
greater detail below. Additionally, as will be discussed 
In greater detail below, the application program 205 re- 
ceives PDOSt of the text shown In the dropdown menu 36 

10 from the action plug-In 225. This process occurs when 
the application program 205 Is Initially executed and the 
action plug-in 225 reglstera itself with the application 
program 205. Additional details regarding this registra- 
tion process will be described below with referance to 

IS FIGURE 4. 

[0051] Refening now to FIGURE 4, an Illustrative rou- 
tine 400 vAW be described for registering the number 
converaion software components with the application 
program 205. In particular, when the action plug-in 225 

20 sn6 the recognizer plug-in 220 for converting numbers 
are first executed, they are registerad with the applica- 
tion program 205. By registering with the application 
program 205, the application program 205 Is nrtade 
aware of the software components and enabled for use 

25 with the schema types recognized by the recognizer 
plug-in 220. Moreover, the action Items to be displayed 
to the user corresponding to each schema type are also 
enumerated to the application program 205 so that the 
application program 205 can display the dropdown 

30 menu 36 when a number 32 or indicator 34 Is selected 
by a user. 

[0052] The routine 400 begins at block 402, where the 
current user Interface language is identified. As dis- 
cussed briefly above, the current user interface lan- 

35 guage may be stored in the language settings 26 main- 
tained by the operating system 1 6 or the application pro- 
gram 205. Once the cun^ent user interface language has 
been Identified, (he routine 400 continues to bloclc 404. 
At block 404, the action plug-in 225 consults the con- 

40 version settings file 28, and generates action menu 
items for defined conversions that are specified for op- 
eration with all languages. In particular, the action plug- 
in 225 creates action menu Hems for all defined conver- 
sions that Include the phrase "ALL" in the field 60A of 

45 the conversion settings file 28. The routine 400 then 
continues to blocl^ 406. 

[0053] At block 406, action menu items are also gen- 
erated for each defined conversion that has an entry in 
field 50A corresponding to the current user interface Ian- 

50 guage. In this manner, action menu items are generated 
only for those conversions enabled for use with all user 
interface languages and for those conversions enabled 
for use with the current user interface language, it 
should be appreciated that the action menu Items are 

55 generated on a per source unit name basis. In this man- 
ner, many separate dropdown menus 36 may be gen- 
erated, one for each source unit name. Moreover, a sep- 
arate schema name is utilized for each source unit name 
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and current user interface language. In this manner, re- 
gardless of the source unit name or current user Inter- 
face language, an appropriate dropdown menu 36 will 
be presented. 

[0054] From block 406, the routine 400 continues to « 
block 408, where the action menu Items for each sche- 
ma are returned to the applteation program 205. Accord- 
ing to one embodiment of the Invention, the application 
program 205 displays the dropdown menu 36 In re- 
sponse to the selection of a number 32 or an indteator 
34. However, it should be appreciated that the action 
plug-In 225 or other software component may be re- 
sponsible for the display of the dropdown menu 36. The 
routine 400 continues from block 408 to block 410, 
where it ends. 

[0055] Turning now to FIGURE 5, an illustrative rou- 
tine 500 will be described for processing the Input of a 
new string at the application program 205. The routine 
500 begins at block 502. where the applicatton program 
205 receives a new string, such as when a user enters 20 
a new paragraph into an electronic document or edits a 
prevtously entered paragraph. From block 502, the rou- 
tine 500 continues to block 604 where the application 
program 205 passes the new string to the recognizer 
DLL 210. As described above, the recognizer DLL 210 25 
is responsible for communicating with the applkiation 
program 205, managing the jobs that need to be per- 
formed by the recognizer plug-ins 220A-220N, receiving 
results from the recognizer plug-Ins 220A-220N, and 
sending schema Information to the application program 3o 
module 205 for recognized numbers and source unit 
names. It shoukJ be understood that, in one embodiment 
of the Invention, a paragraph is passed to the recognizer 
DLL 210 at block 504. However, in alternative embodi- 
ments, a sentence, the contents of a spreadsheet cell, 36 
a section of the document, the entire document, etc., 
may be passed to the recognizer DLL 210. In other 
words, It should be appreciated that the embodiments 
of the present invention are not limited to simply passing 
a paragraph to the recognizer DLL 210. ^ 
[0056] From block 504, the routine 500 continues to 
block 506, where the recognizer DLL 21 0 passes the 
string to the recognizer plug-Ins 220A-220N. The routine 
500 then continues to block 508 where the recognizer 
plug-ins are executed on the paragraph to recognize key 45 
words or characters within the string. In particular, the 
recognizer plug-In for converting numbers between 
measurement systems is executed on the string. An il- 
lustrative routine describing the operation of the recog- 
nizer plug-in for number conversion is described below so 
with reference to FIGURE 6. 

[0057] At block 510, the results from the recognizer 
plug-In 220 are received at the recognizer DLL 210. The 
routine 500 then continues to block 512, where a deter- 
mination is made by the recognizer DLL 210 as to ss 
whether the paragraph has been edited since the string 
was transmitted to the recognizer plug-Ins 220A-220N. 
If the paragraph has been edited, the routine 500 returns 
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to block 504. where the edited string Is passed to the 
recognizer DLL 210. If the paragraph has not been ed- 
ited, the routine 500 continues to block 614. where the 
recognizer DLL 210 sends the results received from the 
recognizer plug-In 220 to the applicatton program 205. 
The routine 500 then continues to block 516, where it 
ends. 

[0058] Referring now to FIGURE 6, an Olustrath^e rou- 
tine 600 will be described that illustrates the operation 
of the recognizer plug-In 220 for converting numbers be- 
tween units of measure according to one embodiment 
of the present invention. The routine 600 begins at block 
602, where a string of text is received at the recognizer 
plug-In 220 from the recognizer DLL 210. The routine 
600 then continues to block 604, where a detemnination 
Is made as to whether the string of text contains a 
nunfU)er. 

[0059] From block 604. the routine 600 continues to 
block 606, where a determination is nrwde as to whether 
a number was found In the string of text. If no digits were 
found, the routine 600 branches from block 606 to bkxjk 
61 4, where It retunns to btock 510. shown In RGURE 5. 
ff . however, at block 606, it Is detemnlned that digits were 
found In the string of text, the routine 600 continues to 
block 608, 

[0060] At block 608, text tocated after the identified 
digits Is scanned to detennine whether a source unit 
name Is associated with the number. For example, the 
recognizer plug-in 220 may scan the text after the Wen- 
llfied digits for the source unit names 'km", "ib", 'ml", 
and other source unit names. The list of the source unit 
names that the recognizer plug-In 220 searches for is 
defined by the field SOB of the conversion settings file 
28. 

[0061] From block 608 the routine 600 continues to 
block 610 where a detenmination is made as to whether 
a source unit name associated with the recognized 
number was tocated. If no source unit name was found, 
the routine 610 branches to block 614, where It relums 
to block 51 0, shown In FIGURE 6. If a source unit name 
was found that is associated with the recognized 
number, the routine 600 continues to block 612. 
[0062] At block 612. schema Information is returned 
to the recognizer DLL 2 1 0. In parttoular. a schema name 
associated with the source unit name and the currently 
enabled language Is returned to the recognizer DLL 21 0. 
Additionally, a 'property bag" may also be retumed to 
the recognizer DLL 210. The property bag is an object 
which stores Infonnation about the recognized number 
that may be utilized by the action plug-in 225. For in- 
stance, the property bag may include a fonmat number 
indicating generally which fomnat the recognized 
number was written In. Additionally, an index to the rec- 
ognized number within the string of text may also be re- 
tumed to the recognizer DLL 210. All of the Infonnation 
retumed from the recognizer plug-In 220 to the recog- 
nizer DLL 210 may be subsequently passed to the ac- 
tion plug-In 225 and used in the conversion process. 
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Tills Is described in greater detail below wfth respeti to 
FIQURES 7 and 8. From block612, the routine 600 con- 
tinues to block 614, where It returns tobk)Ck 510, shown 
in FIGURE 5. 

[0063] Referring now to FIGURE 7, an Illustrative rou- 
tine 700 will be described for processing the selection 
of a semantically categorized nuntber ha>nng an asso- 
ciated unit nanr>e. As discussed above, once a number 
has t>een recognized within a string of text by the rec- 
ognizer plug-in 220A as having an associated unit 
name, the number may be highlighted or an IrKlication 
may be provided to the user indicating that the number 
has been recognized and that actions may be pert omied 
on the number. Accordingly, at block 702, a detemilna- 
tion Is made as to whether the number or indicator has 
been selected by a user. If the number has not been 
selected, the routine 700 continues to block 71 4, where 
It ends. If, however, the number or Indicator has been 
selected, the routine 700 continues to block 704. 
[0064] At block 704, the appllcatk>n program 205 dis- 
plays the list of actions associated with the schema cor- 
responding to the selected number. In this manner, the 
dropdown menu 36 described above with reference to 
FIGURE 3A is presented to the user The routine 700 
then continues from block 704 to block 706, where a de- 
termination is made as to whether the user has selected 
one of the Items from the list of actions. If the user has 
made the selection of a user Interface Item other than 
one of the Items from the list of actions, the routine 700 
branches to btock 710, where the list of actions is re- 
moved. If. however, the user does select one of the 
Items from the list of actions, the routine 700 continues 
to block 708. 

[0065] At block 708, the application program 205 calls 
the action plug-in 225 corresponding to the appropriate 
schema t^e and indicates that an action item has been 
selected. The call from the application program 225 to 
the action plug-in 225 Includes the schema name cor- 
responding to the recognized number, the item number 
of the selected menu item, the name of the calling ap- 
plication program 205, a pointer into an object model 
provided by the application program 205 for accessing 
the document 24, the property bag described above with 
reference to FIGURE 6, and the text of the recognized 
number. The routine 700 then continues to block 712, 
where the action plug-in for converting numbers be- 
tween measurement units Is executed. An iilustrative 
routine for executing the action plug-In 225 for number 
conversion is described below with reference to FIG- 
URE 8. Once the action plug-in 225 has completed its 
execution, the routine 700 continues from block 712 to 
block 714, where It ends. 

[0066] Referring now to FIGURE 8, an illustrative rou- 
tine 800 will be described for executing an action plug- 
In 225 for converting numbers between measurement 
systems. The routine 800 begins at block 802. where 
the action plug-in 225 receives a call from the action DLl 
215 indicating that the user has selected an action menu 



item. From block 802, the routine 800 continues to btock 
804. where the action plug-in 225 determines the actual 
value of the recognized number In view of a format as- 
sociated with tiie language in which the string containing 
5 the number is expressed. This is necessary because 
numbers expressed In different languages may Include 
separator chamcters that have different meanings In dif- 
ferent languages. For instance, a number may be ex- 
pressed In French as "1,729', while In English It would 
10 be expressed as "1729.* Therefore, at block 804, the 
action plug-in 225 identifies the regional format for the 
number from the language settings file 26 based on the 
language in which the number Is expressed. Using the 
regional fontiat, the actual value of the number can be 
IS determined. 

[0067] From block 804, the routine 800 continues to 
block 806, where the recognized number is converted 
to the destination unit of measure according to the se- 
lected action menu Hem. In partteular, the value of the 
field 50J of tiie conversion settings file 28 for the select- 
ed conversion may be utilized to convert the recognized 
and selected number. The value of the field 501 In the 
conversion settings file 28 may also be utilized to round 
the converted number to the appropriate number of dig- 
its. 

[0068] From block 806. the routine 800 continues to 
block 808. where the converted number is fonriatted. 
The converted number may be formatted according to 
the regional format specified in the language settings 
file 26. Moreover, the value of field 50H in the conversion 
settings file 28 may be utilized to format the spacing be- 
tween the converted number and the destination unit 
name. Other types of fonnatting may also be applied to 
Uie converted number. 

[0069] From btock 808, the routine 800 continues to 
block 810 where ttie number in the string of text Is re- 
placed with the converted number. According to one em- 
bodiment of tiie present Invention, the replacement Is 
made by accessing a document object model provided 
by the application program 205. Through the document 
object model, tiie action plug-in 225 can directty access 
the document 24 and make changes therein. Details re- 
garding the use of such a document object model are 
well known to those skilled In the art. Alternatively, the 
converted number and its associated unit name may be 
displayed to the user. From block 810, the routine 800 
continues to block 812, where it returns to block 714, 
described above with reference to FIGURE 7. 
[0070] Based on the foregoing, those skilled in the art 
should appreciate that various embodiments of the 
present invention provide a method, system, apparatus, 
and computer-readable medium for converting numbers 
between units of measure based upon semantically la- 
beled strings. The above specification, examples and 
data provide a complete description of the manufacture 
and use of the composition of the invention. Since many 
embodiments of the Invention can be made without de- 
parting from the spirit and scope of the Invention, the 
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InvenUon resides In the claims hereinafter appended. 



Claime 

1. In a system for creating and editing an electronic 
document, a method for converting a number be- 
tween two systems of measurement, the method 
comprising; 

detenninlng whether a string of text contained 
within the electronic document contains a 
number having an associated unit name; 
In response to detemntnlng that the string of text 
includes a number having an associated unit 
name, semanticaily labeling the number with 
schema infomnation identifying the unit name 
as a source unit of measure; 
providing a list of actions that may be performed 
on the nunr^r to convert the number to a des- 
tination unit of measure, the list of actions iden- 
tified based upon the schema infomnation; 
receiving a selection of an action from the list 
of actions; and 

generating a converted number by converting 
the numl>er from the source unit of measure to 
the destination unit of measure identified by the 
selected action. 

2. The method of Claim 1, wherein operating a con- 
verted number by converting the number from the 
source unit of measure to the destination unit of 
measure identified by the selected action compris- 
es: 

retrieving from a conversion settings file a con- 
version ratio or formula corresponding to the 
selected action; and 

generating a converted number by converting 
the number from the source unit of measure to 
the destination unit of measure with the conver- 
sion ratio or formula. 

3. The method of Claim 2, wherein the conversion set- 
tings file comprises a conversion ratio or fomiuia 
corresponding to one or more measurement con- 
versions, and wherein the method further compris- 
es receiving from a user a user-defined conversion 
ratio or formula and storing the user-defined ratio 
or formula in the conversion settings file. 

4. The method of Claim 1 . further comprising: 

replacing the number and the associated unit 
name with the converted number and a unit 
name associated with the destination unit of 
measure. 



5. The method of Claim 4. wherein replacing the 
number and the associated unit name with the con- 
verted numt>er and a unit name assodaled with the 
destination unit of measure comprises utilizing a 

5 document object model provided by an appGcation 
for editing the electronic document to replace the 
number and the associated unit name with the con- 
verted number and a unit name associated with the 
destination unit of measure. 

10 

6. The method of Claim 5, wherein the list of actions 
comprises a dropdown n>enu having one or more 
menu items coresponding to the list of actions that 
may be performed on the number to convert the 

f5 number to the destination unit of measure. 

7. The method of Claim 6. further comprising: 

detemnintng a current user interface language 
20 setting for the application; and 

generating the menu items of the dropdown 
menu in a language specified by the cunrent us- 
er Interface language setting. 

26 8. The method of Claim 7, wherein generating the 
menu items of the dropdown menu comprises: 

generating menu Items enabled for use with all 
languages; and 
30 generating menu items enabled for use with the 

language specified by the current user Interface 
language setting. 

9, The method of Claim 8. further comprising dispiay- 
35 ing the number and an indication that the number 
has been semanticaily labeled, and wherein the list 
of actions Is provided in response to the selection 
of the number or the Indication. 

40 10. The method of Claim 9, wherein the schema infor- 
mation comprises data uniquely corresponding to 
the source unit of measure and the language spec- 
ified by the cun'ent user interface language setting. 

45 11. The method of Claim 10, further comprising: 

determining a value of the number prior to con- 
verting the number based upon a format asso- 
ciated with the language In which the string of 
50 text is expressed. 

12. A computer-readable medium comprising cooapu- 
ter-readable instructions which, when executed by 
a computer, cause the computer to perform the 

55 method of Claim 2. 

13. A computer-controlled apparatus capable of per- 
forming the method of Claim 2. 
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14. In a system for creating and editing an electronic 
document, a method for converting a number be- 
tween two systems of measurement, the method 
comprising: 

receiving a portion of the electronic document 
as a string of text; 

analyzing the string of text to determine wheth- 
er the string of text Includes a number having 
an associated unit name; 
in response to determining that the string of text 
Includes a number having an associated unit 
name, semanticalty labeling the number with 
schema Information Identifying the unit name 
as a source of measure; 
displaying the numt>er and the unit name and 
an indication that the number has been soman- 
ticaliy labeled; 

receding a selection of the number or the indi- 
cation; 

in response to receiving the selection of the 
number or the Indication, providing a list of ac- 
tions that may foe performed on the number to 
convert the number to a destination unit of 
measure; 

receiving the selection of an action from the list 
of actions; 

in response to receiving the selection of an ac- 
tion, determining a value for the number based 
upon a fomnat associated with a language in 
which the string of text is expressed; 
generating a converted number by converting 
the value to the destination unit of measure 
identified by the selected action; and 
replacing the number with the converted 
number in the string of text. 

15. The method of Claim 14, wherein the list of actions 
comprises a dropdown menu having one or nwre 
menu items con-esponding to the list of actions that 
may be performed on the number to convert the 
numtwr to the destination unit of measure. 

16. The method of Claim 15, further comprising: 

determining a cun^nt user Interface language 
setting for an application program associated 
with the electronic document; and 
generating the menu Items of the dropdown 
menu in a language specified by the current us- 
er Interface language setting. 

17. The method of Claim 16, wherein generating the 
menu items of the dropdown menu comprises: 

generating menu Items enabled for use with all 
languages; and 

generating menu items enabled for use with the 



language specified by the current user interface 
language setting. 

18. A computer-readable medium comprising compu- 
5 ter-readable instnictions which, when executed by 

a computer, cause the computer to perform the 
method of Claim 14. 

19. A computer-controlled apparatus capable of per- 
10 forming the method of Claim 14. 

20. A system for converting a number between two sys- 
tems of measurement, the system comprising: 

a recognizer plug-in capable of receiving a por- 
tion of an electronic document as a string of text 
from an application program, analyzing the 
string of text to detennine whether the string of 
text Includes a number having an associated 
unit name, and in re^nse to detemnlnlng that 
the string of text includes a numt>er having an 
associated unit name, semantlcally labeling the 
number with sctwma Infomiation identifying the 
unit name as a source unit of measure and 
Identifying the language used to express the 
string of text; 

an application program for creating and editing 
the electronic document, the application pro- 
gram capable of displaying the string of text and 
an Indication that the number has been seman- 
ticalty labeled, receiving a selection of the 
number or the indication, In response to receiv- 
ing the selection of the number or the indica- 
tion, providing a list of actions that may be per- 
fomned on the number to convert the number to 
a destination unit of measure, receiving the se- 
lection of an action from the list of actions, and 
providing the selected action and the number 
to an action plug-In; and 
an action plug-In capable of generating a con- 
verted number by converting the number to the 
destination unit of measure identified by the se- 
lected action, and replacing the number with 
the converted number and a unit name corre- 
sponding to the destination unit of measure in 
the string of text. 

21. The system of Claim 20, wherein the list of actions 
comprises a dropdown menu having one or more 

50 menu items corresponding to the list of actions that 
may be performed on the number to convert the 
number to the destination unit of measure, and 
wherein the action plug-in is further operative to: 

55 detennine a cunrent user interface language 

setting for the application program: and to 
generate the menu items of the dropdown 
menu in a language specified by the current us- 
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er Interface language setting. 

22. The system of Claim 21 , wherein the action plug-In 
Is further operative to identify one or more enabled 
languages for the application program and to gen- 5 
erate menu Items enabled for use with all languag- 
es, and to generate menu Items enabled for use 
with the language specified by the current user in- 
terface language setting. 
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